package com.swotxu.mall.ware.dao;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.swotxu.mall.ware.entity.WareSkuEntity;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 商品库存
 * 
 * @author swotxu
 * @email mr_xudada@163.com
 * @date 2020-12-12 18:53:50
 */
@Mapper
public interface WareSkuDao extends BaseMapper<WareSkuEntity> {

    /**
     * 增加指定商品库存
     *
     * @param skuId
     * @param wareId
     * @param stock
     */
    void addStock(@Param("skuId") Long skuId, @Param("wareId") Long wareId, @Param("stock") Integer stock);

    /**
     * 查出skuIds对应的库存信息
     * @param skuIds
     * @return
     */
    List<WareSkuEntity> getSkuHasStock(@Param("skuIds")List<Long> skuIds);

    /**
     * 获取有库存的仓库列表
     * @param skuId skuId
     * @param num   预扣除数量
     */
    List<Long> listWareIdHasSkuStock(@Param("skuId")Long skuId, @Param("num")Integer num);

    /**
     * 更新锁库存
     * @param skuId     skuId
     * @param wareId    仓库Id
     * @param num       要锁的商品数量
     * @return  1-成功 0-失败
     */
    Long lockSkuStock(@Param("skuId")Long skuId, @Param("wareId")Long wareId, @Param("num")Integer num);
}
